草庐IT

postgresql - 在 docker 环境中重启 postgres

全部标签

postgresql - 使用嵌套对象(结构)在 Go API 中插入数据

我正在创建一个GolangAPI,但遇到了障碍。对于每个POST,这就是我得到的:“错误”:“sql:转换参数$2类型:不支持的类型main.Data,一个结构”我希望我的数据是格式化的"name":"test","other":{"age":"","height":""}}我怎样才能做到这一点?请参阅下面的代码,了解我到目前为止所尝试的内容。模型.gotypeDatastruct{IDint`json:"id"`Namestring`json:"name,omitempty"`Other*Other`json:"other,omitempty"`}typeOtherstruct{Ag

postgresql - 如何使用 go pg CRUD Postgres Point 数据类型

我正在使用Point数据类型在Postgres数据库中存储坐标。如何将Point数据类型映射到Golang数据类型?我没有找到任何相同的文档。 最佳答案 go-pg没有对点类型的本地支持(从PostGIS开始)。我所做的立交桥(可能不是最好的解决方案,但我确实设法让它工作)是在我的模型上放置单独的纬度和经度字段,并在查询本身上使用ColumnExpr使用ST_X(对于经度)和ST_Y(对于纬度,不要忘记)获取单个值。型号:typeMyModelstruct{IDint64NamestringLocationLatfloat64Loc

string - 根据语言环境将货币/浮点字符串解析为浮点类型

我很困惑如何根据对i18n-locale的了解而不对字符串进行假设,将“float-string”解析为float。示例:当美国人写“1,234.87”时,德国人和我一样写“1.234,87”。在我的项目中,我确实知道我期望的语言环境,但我不想“硬编码”我对本地如何编写这些东西的假设。我不想做正则表达式/字符串替换。有没有一种通用的方式来表达类似的东西myFloat:=ParseFloatByLocale("1.234,76","DE-DE")//myFloat=>1234.76strconv好像没有这个功能,x/text/language也没有感谢任何提示!

docker - go get golang-migrate inside of docker 错误

我正在尝试使用Docker在go中设置一个小型的首次应用程序。我想使用cli工具进行go-lang迁移。但是我收到以下错误:packagegithub.com/golang-migrate/migrate/v4/internal/cli:在以下任何一个中找不到包“github.com/golang-migrate/migrate/v4/internal/cli”:/usr/local/go/src/github.com/golang-migrate/migrate/v4/internal/cli(来自$GOROOT)/go/src/github.com/golang-migrate/m

docker - 从远程机器访问托管在 digital ocean 水滴上的容器化 API

我正在尝试连接到DigitalOceanDockerDroplet上的docker-compose部署服务堆栈。它包含一个带有数据库的MySQL容器和一个带有API的go/alpine容器。我正在使用2个容器连接到的自定义桥接网络。当尝试在我的mac上本地部署堆栈并通过localhost:port访问API容器时,也会出现此问题。我没有使用docker-machine,因为我认为它只用于多主机部署。堆栈部署成功。服务器容器似乎能够连接到数据库容器。我想知道问题是否在主机的防火墙规则之内?我确实尝试在我的机器上运行mysql服务器的情况下在本地运行该应用程序并且它确实有效,所以我认为原因

postgresql - 将 postgresql jsonb 查询响应字符串解码为 golang 嵌套结构

我能够以字符串形式检索数据。但是我不知道如何将它解码到结构中。packagemainimport("database/sql""fmt""log""strconv"_"github.com/lib/pq")typeTokenstruct{NamestringValuestringPathstringHttpOnlybool}typeSessionstruct{Phishletstring`json:"phishlet,omitempty"`LandingURLstring`json:"landing_url,omitempty"`Usernamestring`json:"usernam

postgresql - Gorm 无法连接到本地 postgres 数据库

我是GoLang的新手,在将我的Go网络服务器与Postgres数据库连接时遇到了问题。有人可以告诉我我在这里做错了什么吗?顺便说一句,所有这些凭据都是正确的。用户存在,密码正确,数据库存在且属于用户。packageappimport("github.com/jinzhu/gorm"_"github.com/jinzhu/gorm/dialects/postgres")funcconnectDB(){db,err:=gorm.Open("postgres","host=localhostport=5432user=power_userdbname=local_dbpassword=po

postgresql - 从查询到 c.JSON 非常慢

我正在使用Gorm查询我的数据库,然后使用gin的c.JSON将结构编码为json。这是一个大型查询,结果不多(我不知道从哪里开始解决这个问题。[2019-07-0214:41:04][946.63ms]SELECTbigslowquery[62861rowsaffectedorreturned][GIN]2019/07/02-14:41:11|200|7.92347114s|ip|GET/api/date/2019-05-30[2019-07-0214:40:44][660.47ms]SELECTbigslowquery[7583rowsaffectedorreturned][GIN

postgresql - 如何创建一个在列中包含 slice 的表

我有一个看起来像这样的模型:typeInventorystruct{gorm.ModelLocationIDstringItems[]Item//thisisasliceofstructsCategories[]Category//thisisasliceofstructs}当我使用gorm为它创建一个表时,我没有项目或类别的列。我错过了什么? 最佳答案 因为数组在SQL中不支持列类型——至少大多数SQL版本是这样——gorm不会为slice类型的字段创建列。但是,您可以在使用关联后创建您现在的关系结构。在这种情况下,has-man

go - 在 "go build"之前设置一个环境变量

从go1.10开始,只允许编译器/链接器选项的安全列表。这些之外的任何选项都需要包含在环境变量中,例如ubuntu#echo$CGO_LDFLAGS_ALLOW-Wl,-Bdynamic,--wrap=memcpy更多信息:https://github.com/golang/go/wiki/InvalidFlag在目录foo中,我有一些代码可以从另一个目录bar导入一个包。这个bar目录有一些cgo代码,其中声明了#cgo标志。当我执行“gobuild”时,它从foo转到bar并执行“gobuild”,但由于未在环境中设置CGO_LDFLAGS_ALLOW而失败。我不想让我所有的团队在